package com.five.reader.mapper;

import com.five.pojo.ReadHistory;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface ReadHistoryMapper {

    /**
     * 根据ID查询阅读记录
     */
    ReadHistory selectById(Long id);

    /**
     * 根据读者ID查询阅读记录
     */
    List<ReadHistory> selectByReaderId(Long readerId);

    /**
     * 根据读者ID和小说ID查询阅读记录
     */
    List<ReadHistory> selectByReaderAndNovel(@Param("readerId") Long readerId, @Param("novelId") Long novelId);

    /**
     * 查询读者最近阅读记录
     */
    List<ReadHistory> selectRecentByReaderId(@Param("readerId") Long readerId, @Param("limit") Integer limit);

    /**
     * 插入阅读记录
     */
    int insert(ReadHistory readHistory);

    /**
     * 更新阅读记录
     */
    int update(ReadHistory readHistory);

    /**
     * 删除阅读记录
     */
    int deleteById(Long id);

    /**
     * 根据读者ID删除阅读记录
     */
    int deleteByReaderId(Long readerId);

    /**
     * 统计读者阅读时长
     */
    Integer sumReadTimeByReaderId(Long readerId);

    /**
     * 统计小说阅读次数
     */
    Integer countReadByNovelId(Long novelId);
}